package com.atguigu.gulimall.seckill;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

/**
 * 1、整合Sentinel
 *  1. 导入依赖 spring-cloud-starter-alibaba-sentinel
 *  2. 下载sentinel的控制台
 *  3. 配置Sentinel
 *  4. 在控制台调整所有的参数[默认所有的流控设置保存在内存中，重启失效]
 * 2、每一个微服务都要导入actuator统计审核信息:并配置 management.endpoints.web.exposure.include=*
 * 3、自定sentinel流控返回数据
 *
 * 4、使用Sentinel来保护feign远程调用：
 *      1.调用方的熔断保护feign.sentinel.enabled=true
 *      2.调用方手动指定远程服务的降级策略。远程服务被降级处理，触发我们的熔断回调方法
 *      3.超大浏览的时候，必须牺牲一些远程服务。在服务的提供方（远程服务）指定降级策略; 提供方是在运行。但是不运行自己的业务逻辑。返回的是默认的降级数据（限流的数据）
 *
 * 5、自定义受保护资源
 *  1、基于代码的 自定义受保护资源
 *     try(Entry entity = SphU.entry("自定义受保护资源名")) {
 * 	    // 业务逻辑
 *      } catch (BlockException e) {
 *   	   //一定要配置被限流以后的默认返回
 *      }
 *  2、基于注解
 *      @SentinelResource(value = "getCurrentSeckillSkusResource",blockHandler = "blockHandler")
 *   无论是1、2方式一定要配置被限流以后的默认返回。
 *   url请求可以设置统一返回：WebCallbackManager
 *
 */
@EnableRedisHttpSession
@EnableFeignClients
@EnableDiscoveryClient
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
public class GulimallSeckillApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimallSeckillApplication.class, args);
    }

}
